Spring Boot এবং JPA Auditing

Java Technologies - স্প্রিং বুট ওআরএম (Spring Boot ORM)
192

JPA Auditing হলো একটি প্রক্রিয়া যা স্বয়ংক্রিয়ভাবে এন্টিটি অবজেক্টগুলিতে সময়, ব্যবহারকারী এবং অন্যান্য অডিট তথ্য যোগ করে। এই প্রক্রিয়াটি বিশেষভাবে ব্যবহৃত হয় যখন ডেটাবেস টেবিলে ডেটা সংশোধনের সময় পরিবর্তন বা ট্র্যাকিং প্রয়োজন হয়, যেমন- created_at, updated_at, created_by, updated_by ইত্যাদি। Spring Boot এবং JPA Auditing এর মাধ্যমে ডেটাবেস টেবিলে এ ধরনের অডিট তথ্য সংরক্ষণ সহজ হয়ে যায়।


JPA Auditing এর সুবিধা

  1. অটোমেটেড অডিট তথ্য: ডেটা যখন তৈরি বা আপডেট হয়, তখন এটি স্বয়ংক্রিয়ভাবে টাইমস্ট্যাম্প এবং ব্যবহারকারীর তথ্য সংরক্ষণ করে।
  2. ডেটা ট্র্যাকিং: কে কখন ডেটা তৈরি বা পরিবর্তন করেছে, তা সহজেই ট্র্যাক করা যায়।
  3. পারফরম্যান্স উন্নতি: অডিটিং তথ্য ম্যানুয়ালি আপডেট না করে, Spring Boot এবং JPA Auditing দিয়ে স্বয়ংক্রিয়ভাবে এটি করা যায়, যা কোড সহজ এবং মেইনটেন করা সহজ।

Spring Boot এ JPA Auditing কনফিগারেশন

Spring Boot এবং JPA Auditing ব্যবহার করার জন্য কয়েকটি কনফিগারেশন করা প্রয়োজন। নিচে বিস্তারিত নির্দেশনা দেওয়া হলো।

১. @EnableJpaAuditing এনোটেশন

Spring Boot অ্যাপ্লিকেশনে JPA Auditing সক্রিয় করতে @EnableJpaAuditing এনোটেশন ব্যবহার করতে হয়। এটি সাধারণত অ্যাপ্লিকেশনের প্রধান কনফিগারেশন ক্লাসে যুক্ত করা হয়।

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.data.jpa.repository.config.EnableJpaAuditing;

@SpringBootApplication
@EnableJpaAuditing
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

২. @CreatedBy, @LastModifiedBy, @CreatedDate, @LastModifiedDate এনোটেশন

JPA Auditing-এ ব্যবহৃত মূল এনোটেশন গুলি হলো:

  • @CreatedBy: ডেটা যখন তৈরি হয়, তখন এটি যে ব্যবহারকারী দ্বারা তৈরি হয়েছে তা স্টোর করে।
  • @LastModifiedBy: ডেটা যখন আপডেট হয়, তখন এটি যে ব্যবহারকারী দ্বারা আপডেট হয়েছে তা স্টোর করে।
  • @CreatedDate: ডেটা তৈরি হওয়ার তারিখ ও সময়।
  • @LastModifiedDate: ডেটা আপডেট হওয়ার তারিখ ও সময়।

৩. AuditorAware কনফিগারেশন

@CreatedBy এবং @LastModifiedBy ব্যবহার করতে হলে AuditorAware ইন্টারফেসটি কনফিগার করতে হয়, যা ব্যবহারকারী সম্পর্কিত তথ্য প্রদান করবে।

import org.springframework.data.domain.AuditorAware;
import org.springframework.stereotype.Component;
import java.util.Optional;

@Component
public class AuditorAwareImpl implements AuditorAware<String> {

    @Override
    public Optional<String> getCurrentAuditor() {
        // এখানে আপনি যে ব্যবহারকারীকে অ্যাক্সেস করছেন, তার নাম ফেরত দিন
        // বর্তমানে আমরা একটি স্ট্যাটিক ভ্যালু দিচ্ছি
        return Optional.of("admin");
    }
}

৪. Entity ক্লাসে Auditing এনোটেশন ব্যবহার

JPA Entity ক্লাসে @CreatedDate, @LastModifiedDate, @CreatedBy, @LastModifiedBy এনোটেশন যোগ করতে হবে।

import org.springframework.data.annotation.CreatedDate;
import org.springframework.data.annotation.LastModifiedDate;
import org.springframework.data.jpa.domain.support.AuditingEntityListener;
import jakarta.persistence.*;

import java.time.LocalDateTime;

@Entity
@EntityListeners(AuditingEntityListener.class)
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String name;
    private String email;

    @CreatedDate
    private LocalDateTime createdDate;

    @LastModifiedDate
    private LocalDateTime lastModifiedDate;

    @CreatedBy
    private String createdBy;

    @LastModifiedBy
    private String lastModifiedBy;

    // Getters and Setters
}

৫. application.properties কনফিগারেশন

JPA Auditing স্বয়ংক্রিয়ভাবে কাজ করার জন্য কিছু অতিরিক্ত কনফিগারেশন করতে হবে।

spring.jpa.properties.hibernate.ejb.interceptor=org.hibernate.EmptyInterceptor
spring.jpa.hibernate.ddl-auto=update

উদাহরণ: JPA Auditing এর ব্যবহার

  1. অ্যাপ্লিকেশন শুরু হলে: প্রথমবার যখন User অবজেক্টটি তৈরি হবে, তখন createdDate, lastModifiedDate, createdBy, এবং lastModifiedBy স্বয়ংক্রিয়ভাবে পূর্ণ হবে।
  2. এনটিটি আপডেট হলে: পরবর্তীতে যখন User অবজেক্টটি আপডেট হবে, তখন lastModifiedDate এবং lastModifiedBy স্বয়ংক্রিয়ভাবে আপডেট হবে।
@Autowired
private UserRepository userRepository;

public void createOrUpdateUser() {
    // নতুন ইউজার তৈরি
    User user = new User();
    user.setName("John Doe");
    user.setEmail("john.doe@example.com");
    userRepository.save(user);

    // কিছু সময় পর ইউজার আপডেট
    user.setEmail("john.doe_updated@example.com");
    userRepository.save(user);
}

ডেটাবেসে স্টোর হওয়া ডেটা

IDNameEmailCreatedDateLastModifiedDateCreatedByLastModifiedBy
1John Doejohn.doe@example.com2024-12-21 10:00:002024-12-21 10:00:00adminadmin
2John Doejohn.doe_updated@example.com2024-12-21 10:00:002024-12-21 10:15:00adminadmin

সারাংশ

Spring Boot এবং JPA Auditing ডেটাবেসে ডেটা পরিবর্তনের সাথে সম্পর্কিত অডিট তথ্য স্বয়ংক্রিয়ভাবে সংগ্রহ করতে সহায়ক। এটি অডিটিং তথ্য যেমন createdDate, lastModifiedDate, createdBy, এবং lastModifiedBy ট্র্যাক করতে সাহায্য করে, যা অ্যাপ্লিকেশনের ব্যবস্থাপনা এবং ডেটা ট্র্যাকিং সহজ করে তোলে। Spring Data JPA-র @CreatedBy, @LastModifiedBy, @CreatedDate, @LastModifiedDate এনোটেশনগুলির মাধ্যমে এই ফিচারটি বাস্তবায়িত করা যায়।

Content added By

JPA Auditing এর ধারণা এবং প্রয়োজনীয়তা

188

স্প্রিং বুট (Spring Boot) হল একটি ওপেন সোর্স ফ্রেমওয়ার্ক যা জাভা প্রোগ্রামিং ভাষায় অ্যাপ্লিকেশন ডেভেলপমেন্টকে সহজ এবং দ্রুত করে তোলে। ORM (Object-Relational Mapping) হল একটি টেকনিক যা অবজেক্ট-অরিয়েন্টেড প্রোগ্রামিং ভাষা (যেমন Java) এবং রিলেশনাল ডাটাবেসের মধ্যে ডাটা ট্রান্সফারের প্রক্রিয়া সহজ করে। JPA (Java Persistence API) ORM টেকনোলজির একটি গুরুত্বপূর্ণ অংশ, যা ডাটাবেসের সঙ্গে Java অবজেক্টের সম্পর্ক স্থাপন করতে সাহায্য করে।

JPA Auditing হল একটি সুবিধা যা ডেটাবেসে থাকা তথ্যের পরিবর্তন ও ব্যবহারের ইতিহাস ট্র্যাক করার জন্য ব্যবহৃত হয়। এটি মূলত সেই সমস্ত তথ্য রেকর্ড করে, যেমন কখন ডাটা তৈরি হয়েছে, কে তৈরি করেছে, কখন পরিবর্তন হয়েছে, এবং কে পরিবর্তন করেছে। এই তথ্য গুলি ব্যাবহারকারীদের বা সিস্টেমের নজরদারি ও সুরক্ষা নিশ্চিত করতে সাহায্য করে।


JPA Auditing এর প্রয়োজনীয়তা

JPA Auditing ব্যবহারের বেশ কিছু গুরুত্বপূর্ণ সুবিধা রয়েছে, যেমন:

ডাটা হাইজিন (Data Hygiene) এবং নিরাপত্তা

JPA Auditing ব্যবহারের মাধ্যমে আপনি সহজেই ট্র্যাক করতে পারেন কে কখন এবং কোথায় ডাটা পরিবর্তন করেছে। এটি নিরাপত্তা নিশ্চিত করতে এবং সিস্টেমে কোন ধরনের অনাকাঙ্ক্ষিত পরিবর্তন হচ্ছে কিনা তা মনিটর করতে সাহায্য করে।

অডিট ট্রেইল (Audit Trail)

এটি একটি অডিট ট্রেইল তৈরি করতে সাহায্য করে, যা পরে কোনো ডাটা পরিবর্তনের কারণে যদি সমস্যা তৈরি হয়, তবে আপনি সহজেই নির্ধারণ করতে পারেন সমস্যাটি কোথা থেকে এসেছে এবং কীভাবে তা ঠিক করা যেতে পারে।

কনফর্মিটি (Conformity) এবং রেগুলেটরি কমপ্লায়েন্স

অনেক ক্ষেত্রেই অডিটিং রেকর্ড রাখা একটি আইনি বা ব্যবসায়িক প্রয়োজনীয়তা হয়ে থাকে। JPA Auditing এর মাধ্যমে এটি সহজে করা সম্ভব হয়, যেমন ফিনান্সিয়াল রেকর্ড বা স্বাস্থ্যসেবা সম্পর্কিত তথ্যের জন্য।

ইনফরমেশন ট্র্যাকিং

JPA Auditing আপনাকে আপনার অ্যাপ্লিকেশনের ডাটা ইতিহাস ট্র্যাক করতে এবং অ্যাপ্লিকেশনটির দীর্ঘমেয়াদী বিশ্লেষণ ও পরিসংখ্যান তৈরিতে সাহায্য করে।


JPA Auditing কিভাবে কাজ করে?

JPA Auditing সাধারণত স্প্রিং বুট অ্যাপ্লিকেশনে @EntityListeners এবং @EnableJpaAuditing অ্যানোটেশন ব্যবহার করে কাজ করে। এর মাধ্যমে আপনার সিস্টেমে ডাটার তৈরি, পরিবর্তন এবং মুছে ফেলার সময় বিভিন্ন তথ্য স্বয়ংক্রিয়ভাবে রেকর্ড হয়।

প্রাথমিকভাবে JPA Auditing সেটআপ করার জন্য:

  1. @EnableJpaAuditing অ্যানোটেশনটি আপনার কনফিগারেশন ক্লাসে যোগ করতে হবে।
  2. @CreatedDate, @LastModifiedDate, @CreatedBy, @LastModifiedBy ইত্যাদি অ্যানোটেশনগুলি ব্যবহার করতে হয়।

উদাহরণ:

@Entity
@EntityListeners(AuditingEntityListener.class)
public class Product {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String name;
    
    @CreatedDate
    private LocalDateTime createdDate;

    @LastModifiedDate
    private LocalDateTime lastModifiedDate;

    @CreatedBy
    private String createdBy;

    @LastModifiedBy
    private String lastModifiedBy;
    
    // getters and setters
}

এখানে @CreatedDate, @LastModifiedDate, @CreatedBy, এবং @LastModifiedBy অ্যানোটেশনগুলো ব্যবহার করা হয়েছে যাতে প্রতিটি ক্ষেত্রের তারিখ এবং ব্যবহারকারীর তথ্য স্বয়ংক্রিয়ভাবে রেকর্ড হতে পারে।


সারাংশ

JPA Auditing ব্যবহারের মাধ্যমে স্প্রিং বুট অ্যাপ্লিকেশনে ডেটার পরিবর্তন এবং ইতিহাস ট্র্যাক করা সহজ হয়। এটি শুধু নিরাপত্তার জন্যই নয়, বরং আইনি বা ব্যবসায়িক প্রয়োজনে প্রয়োজনীয় অডিট ট্রেইল তৈরি করার জন্যও গুরুত্বপূর্ণ। JPA Auditing সেটআপ করার মাধ্যমে আপনি আপনার ডেটাবেসের উপর পুরোপুরি নিয়ন্ত্রণ রাখতে পারেন এবং এটি সিস্টেমের গুণগতমান বাড়াতে সহায়ক।


Content added By

@EntityListeners, @CreatedDate, @LastModifiedDate অ্যানোটেশন এর ব্যবহার

181

স্প্রিং বুট (Spring Boot) একটি জনপ্রিয় ফ্রেমওয়ার্ক যা Java-তে দ্রুত অ্যাপ্লিকেশন তৈরি করার জন্য ব্যবহৃত হয়। যখন আমরা ডেটাবেসের সঙ্গে কাজ করি, তখন Object-Relational Mapping (ORM) ব্যবহার করা হয়, যা Java অবজেক্টগুলিকে ডেটাবেস টেবিলের সঙ্গে ম্যাপ করে। Hibernate, JPA (Java Persistence API) এসব ORM টেকনোলজি হিসেবে ব্যবহৃত হয়। এই প্রযুক্তির মধ্যে কিছু অ্যানোটেশন রয়েছে যা ডেটাবেস রেকর্ডের সাথে স্বয়ংক্রিয়ভাবে কিছু কার্যক্রম পরিচালনা করতে সাহায্য করে। এর মধ্যে জনপ্রিয় অ্যানোটেশনগুলি হল @EntityListeners, @CreatedDate, এবং @LastModifiedDate।

@EntityListeners অ্যানোটেশন

@EntityListeners অ্যানোটেশনটি Entity ক্লাসের জন্য event listeners সেট করার জন্য ব্যবহৃত হয়। এটি বিশেষভাবে Entity এর lifecycle events (যেমন পpersist, update, delete) সুনির্দিষ্ট কাস্টম লজিক যোগ করার জন্য ব্যবহৃত হয়।

@Entity
@EntityListeners(AuditingEntityListener.class)
public class Employee {
    // Fields, getters, setters
}

এখানে AuditingEntityListener.class একটি pre-defined listener class যা Entity এর lifecycle events ট্র্যাক করে।

@CreatedDate অ্যানোটেশন

@CreatedDate অ্যানোটেশনটি ডেটাবেস রেকর্ডের তৈরির তারিখ বা সময় স্বয়ংক্রিয়ভাবে ট্র্যাক করতে ব্যবহৃত হয়। যখন একটি নতুন Entity তৈরি হয়, এই অ্যানোটেশনটি সেই Entity-তে creation time ইনজেক্ট করে।

যে কোনো Entity ক্লাসে @CreatedDate ব্যবহারের জন্য @EnableJpaAuditing অ্যানোটেশন ব্যবহার করতে হয়, যা স্প্রিং বুট অ্যাপ্লিকেশনে auditing চালু করে।

@Entity
public class Employee {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @CreatedDate
    private LocalDateTime createdDate;

    // other fields, getters, setters
}

@LastModifiedDate অ্যানোটেশন

@LastModifiedDate অ্যানোটেশনটি Entity এর শেষ আপডেট টাইম ট্র্যাক করতে ব্যবহৃত হয়। যখন Entity তে কোনো পরিবর্তন করা হয়, এটি স্বয়ংক্রিয়ভাবে শেষ পরিবর্তনের তারিখ বা সময় সংরক্ষণ করে।

@Entity
public class Employee {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @LastModifiedDate
    private LocalDateTime lastModifiedDate;

    // other fields, getters, setters
}

auditing এনাবল করা

উপরোক্ত অ্যানোটেশনগুলি কাজ করার জন্য আপনাকে @EnableJpaAuditing অ্যানোটেশনটি স্প্রিং কনফিগারেশন ক্লাসে যোগ করতে হবে, যাতে auditing কার্যক্রম সক্রিয় হয়।

@Configuration
@EnableJpaAuditing
public class JpaConfig {
}

স্প্রিং বুট ORM-এর এই অ্যানোটেশনগুলি ব্যবহার করে আপনি ডেটাবেস রেকর্ডের সাথে সম্পর্কিত বিভিন্ন কার্যক্রম যেমন রেকর্ড তৈরি এবং আপডেট সময় ট্র্যাক করা সহজভাবে করতে পারেন। এটি ডেটাবেসে অন্তর্নিহিত তথ্য সংরক্ষণ করতে এবং অ্যাপ্লিকেশনকে আরো কার্যকরী ও স্বয়ংক্রিয়ভাবে পরিচালনা করতে সহায়তা করে।

Content added By

উদাহরণ সহ JPA Auditing

170

স্প্রিং বুট (Spring Boot) এবং জাভা পেরসিস্টেন্স এপিআই (Java Persistence API বা JPA) এর মাধ্যমে ডেটাবেসের সাথে যোগাযোগ এবং ডেটার কার্যকরী হ্যান্ডলিং করা হয়। JPA Auditing হলো একটি মেকানিজম যা আমাদের ডেটাবেসের অটোমেটিক ট্র্যাকিং এবং টাইমস্ট্যাম্পিংয়ের সুবিধা দেয়। এটি বিশেষ করে তথ্যের সৃষ্টির সময়, পরিবর্তনের সময় এবং মুছে ফেলার সময় ট্র্যাক করতে ব্যবহৃত হয়।


JPA Auditing কি?

JPA Auditing একটি ফিচার যা আপনাকে আপনার ডোমেইন মডেলগুলিতে স্বয়ংক্রিয়ভাবে তথ্য সংরক্ষণ করতে সহায়তা করে। সাধারণত, যখন ডেটাবেসে কোনো রেকর্ড তৈরি, আপডেট বা মুছে ফেলা হয়, তখন ওই অপারেশনের সাথে যুক্ত সময় এবং ব্যবহারকারী সম্পর্কিত তথ্য সংরক্ষণ করা হয়। এটি আপনাকে ডেটা পরিবর্তনের ইতিহাস ট্র্যাক করতে সহায়ক।

JPA Auditing সাধারণত নীচের তথ্যগুলো ট্র্যাক করে:

  • ক্রিয়েটেড_এট (createdAt): রেকর্ডটি কখন তৈরি হয়েছে।
  • ক্রিয়েটেড_বাই (createdBy): রেকর্ডটি কে তৈরি করেছেন।
  • আপডেটেড_এট (updatedAt): রেকর্ডটি কখন আপডেট হয়েছে।
  • আপডেটেড_বাই (updatedBy): রেকর্ডটি কে আপডেট করেছেন।

JPA Auditing কনফিগারেশন

JPA Auditing ব্যবহারের জন্য, আমাদের কিছু কনফিগারেশন এবং এন্টিটি ক্লাসে কিছু পরিবর্তন করতে হয়।

  1. স্প্রিং বুট কনফিগারেশন:
    প্রথমে, @EnableJpaAuditing অ্যানোটেশন ব্যবহার করে স্প্রিং বুট অ্যাপ্লিকেশনটি জেপিএ অডিটিং সক্ষম করতে হবে।

    @Configuration
    @EnableJpaAuditing
    public class JpaConfig {
    }
    
  2. এন্টিটি ক্লাসে অডিটেবল ফিল্ড যোগ করা:
    এরপর, আপনার ডোমেইন মডেলে @CreatedDate, @LastModifiedDate, @CreatedBy, এবং @LastModifiedBy অ্যানোটেশন ব্যবহার করতে হবে।

    উদাহরণস্বরূপ, একটি User এন্টিটি ক্লাস:

    @Entity
    @EntityListeners(AuditingEntityListener.class)
    public class User {
    
        @Id
        @GeneratedValue(strategy = GenerationType.IDENTITY)
        private Long id;
    
        private String username;
    
        @CreatedDate
        private LocalDateTime createdAt;
    
        @LastModifiedDate
        private LocalDateTime updatedAt;
    
        @CreatedBy
        private String createdBy;
    
        @LastModifiedBy
        private String updatedBy;
    
        // Getters and Setters
    }
    
  3. অডিটিং কনফিগারেশন:
    @CreatedBy এবং @LastModifiedBy ফিল্ডগুলির জন্য একটি AuditorAware ইমপ্লিমেন্টেশন দরকার, যা জানাবে কে রেকর্ডটি তৈরি বা আপডেট করেছেন।

    @Component
    public class AuditorAwareImpl implements AuditorAware<String> {
    
        @Override
        public Optional<String> getCurrentAuditor() {
            return Optional.of("Admin");  // এখানে আপনি আপনার ব্যবহারকারীর নাম বা আইডি দিতে পারেন।
        }
    }
    

উদাহরণ সহ ব্যবহার

এখন, আমরা দেখতে পারি কিভাবে এই কনফিগারেশন ও অডিটিং কাজ করে।

  1. রেকর্ড তৈরি করা:
    যখন আপনি User এন্টিটির একটি রেকর্ড তৈরি করবেন, তখন createdAt, createdBy ফিল্ডগুলি স্বয়ংক্রিয়ভাবে পূর্ণ হবে।

    @Autowired
    private UserRepository userRepository;
    
    public void createUser() {
        User user = new User();
        user.setUsername("JohnDoe");
        userRepository.save(user);
    }
    
  2. রেকর্ড আপডেট করা:
    যখন আপনি একটি রেকর্ড আপডেট করবেন, তখন updatedAt এবং updatedBy ফিল্ডগুলি আপডেট হবে।

    public void updateUser(Long userId) {
        User user = userRepository.findById(userId).orElseThrow();
        user.setUsername("UpdatedName");
        userRepository.save(user);
    }
    

JPA Auditing স্প্রিং বুট অ্যাপ্লিকেশনের মধ্যে খুবই শক্তিশালী এবং সহজে কনফিগার করা যায়, যা আপনার ডেটাবেস অপারেশনগুলোকে আরও ট্র্যাকযোগ্য ও ব্যবস্থাপনাযোগ্য করে তোলে।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...